#include<iostream>
#include<algorithm>
#include<vector>

using namespace std;


vector<long long> a;

long long get(long long n,long long k)
{
    for(int i=1;i<=n/i;i++)
    {
        if(n%i == 0)
        {
            a.push_back(i);
            if(n/i!=i) a.push_back(n/i);
        }
    }

    if(k>a.size())return -1;

    sort(a.begin(),a.end());
    //for(int i=0;i<a.size();i++) cout<<a[i]<<' ';
    return a[k-1];
}

int main()
{
    long long n,k;
    cin>>n>>k;
    cout<<get(n,k)<<'\n';
    return 0;
}
